草庐IT

MySQL IF THEN 在 WHERE 子句中

全部标签

mysql - 带有 INNER JOIN 的 SELECT 子句影响行数的奇怪行为? (MySQL 5.1.52)

我的一个测试用例遇到了一个我无法解释的奇怪问题。它归结为一个应该返回1行的查询,而不是返回零。这是失败的查询。SELECTroles.idFROM`roles`INNERJOIN`accounts_roles`ON`roles`.id=`accounts_roles`.role_idWHERE(`roles`.`id`=9)AND(`accounts_roles`.account_id=6)LIMIT1;11:24:07[SELECT-0row(s),0.001secs]Emptyresultsetfetched这是我无法解释的部分。如果我将roles.id更改为*我可以看到那里有数据

mysql - 两个索引列上的 SELECT FOR UPDATE 和 WHERE 条件 - 什么是锁定策略?

这个问题是这个问题的逻辑延续:HowmanyrowswillbelockedbySELECT...ORDERBYxxxLIMIT1FORUPDATE?假设我有这样的选择:SELECTid,statusFROMjobWHEREstatus=XXXANDidIN(1,2,3)FORUPDATEid为主键,status索引在这种情况下,MySQL的锁定策略是什么?锁定仅匹配两个条件的行锁定所有匹配第一个条件的行+分别锁定所有匹配第二个条件的行锁定整个表我认为最合乎逻辑的是2。但是...我不确定。能详细说说吗? 最佳答案 好吧,我进行了测试

mysql - SELECT * FROM Table WHERE colA 和 colB 至少有 3 个相同

我必须将这两个mySQL查询合并为一个。我复制了一个解决方案并将其用于连接表。我正在查询一个包含两列(标记为“to_”和“from_”)的连接表。'to_'和'from_'都保存同一张表的ID号。我需要以这样的方式组合这些查询,以便根据以下条件获得结果:[('from_'+'to_')>3],其中'from_'和'to_'具有相同的值(即,它们指的是相同的ID)。$query="select*fromnodeswherenodeIDin(selectto_fromjoinTablegroupbyto_havingcount(*)>3)";...$query="select*fromno

php - 如何在不带括号的 Zend_Db_Select 语句中使用 "HAVING"子句?

我知道Zend提供了having()方法,但我想要的是这样的查询:SELECTa.*,`as`.*FROM`fruit_db`.`apples`AS`a`INNERJOIN`fruit_db`.`apple_seeds`AS`as`ONa.id=as.apple_idWHERE(a.id=1)ANDas.seed_nameHAVING'johnny'不是“有(as.seed_name='johnny')”回溯一下,我们有表格:fruit_db.apples|id|name|--------------|1|red||2|green|fruit_db.apple_seeds|apple_

mysql - 优化 MySQL - WHERE 和 ORDER BY 使用不同的列

我有一个115MByte、1,600,000行的表,用于存储房价和坐标。“SELECT”查询花费的时间太长。我想知道是否有人可以建议加快速度的方法。我的表的稍微简化的版本....CREATETABLE`prices1`(`price`INT(10)NOTNULL,`address`VARCHAR(127)NOTNULL,`lat`FLOAT(6,4)NOTNULLCOMMENT'GPSlatitude',`lng`FLOAT(6,4)NOTNULLCOMMENT'GPSlongitude',INDEX`lat`(`lat`),INDEX`price`(`price`))ENGINE=M

mysql - 具有多个 where 和 order by 子句的慢查询

我正在尝试寻找一种方法来加速缓慢的(文件排序)MySQL查询。表格:categories(id,lft,rgt)questions(id,category_id,created_at,votes_up,votes_down)示例查询:SELECT*FROMquestionsqINNERJOINcategoriescON(c.id=q.category_id)WHEREc.lft>1ANDc.rgt如果我删除ORDERBY子句,它会很快。我知道MySQL不喜欢在同一个子句中同时使用DESC和ASC命令,所以我尝试添加一个复合(created_at,votes_up)索引到question

php - 从 4 个 where 子句中的每一个中选择 1 个 rand() mysql

使用MySQL和PHP。我正在尝试从表格中随机选择4个广告。1个用于adspot1、1个用于adspot2、1个用于adspot3、1个用于adspot4。这是我的表格的样子:ad_id|ad_spot|ad_html1|3|2|1|3|4|4|2|表中大约有1200个广告,每个广告位都有多条记录,记录随时可能更改。下面是我用来为特定广告位选择1个随机广告的查询:SELECTad_htmlFROMadsWHEREad_spot='2'ORDERBYRAND()LIMIT1我为一个脚本计时,该脚本选择了所有1200条记录并将它们放入一个PHP数组中,然后为每个广告位随机选择1个。这比使用

php - 在 'country_id' 子句中获取列 'where' 是不明确的 - cakephp 1.3 中的搜索查询错误

我正在使用CakePHP1.3版本使用搜索插件来实现搜索功能。我有三个模型:演示,国家国家Demo有两个外键,country_id和state_id。State具有外键country_id。我正在做的是,我有一个搜索表单,其中包含国家和州下拉列表,从国家和州表中获取所有数据。当我从下拉列表中搜索任何国家并提交表格时,它会显示以下错误。如果我只使用状态下拉列表进行搜索,我会得到正确的结果。当我执行搜索查询时,出现错误'Column'country_id'inwhereclauseisambiguous'我的查询是:SELECT`Demo`.`id`,`Demo`.`demo2`,`Dem

mysql - 如何: Find and update all the entries where the value in one column shows up more than once

我有一个包含以下列的表格:subid-资源的idauthorid-作者的id排序-作者在引用中的顺序对于用户可以提交资源并引用多个作者的应用程序。作者可以在他们的投稿中引用主要和次要作者,而且通常会这样做。有一种情况,用户(称他为用户111)提交的所有条目都将自己列为主要作者,实际作者为次要作者。不幸的是,那个人已经离开了这个项目,所以我来解决这个问题(我必须纯粹用sql来做)。我正在尝试弄清楚如何构建一个查询来执行以下操作:查找所有条目subid值在表中出现多次其中至少一个authorid值是111111的排序大于非111的任何用户的排序并更新它们not(111)作者的排序为“0”并

php - Codeigniter where查询自定义

首先,我的数据库表字段中有以下详细信息,如'company_name'=>'TestCompany'。我想在比较输入数据('TestCompany'或'TestCompany'),因为该字符串(测试公司)的存在。请建议查询是否存在。我使用了以下内容,但它在所有情况下都不起作用。$companyname="TestCompany";$this->db->select("*");$companynames=str_replace('','',$companyname);$where="companyin('$companyname','$companynames')";//$where="